<template>
    <div class="f-menu" :style="{ width: $store.state.asideWidth }">
        <el-menu default-active="2" :collapse="isCollapse" class="border-0" @select="handleSelect"
            :collapse-transition="false" unique-opened>
            <template v-for="(item, index) in asideMenus" :key="index">
                <el-sub-menu v-if="item.child && item.child.length > 0" :index="item.name">
                    <template #title>
                        <el-icon>
                            <component :is="item.icon"></component>
                        </el-icon>
                        <span>{{ item.name }}</span>
                    </template>
                    <el-menu-item v-for="(item2, index2) in item.child" :index="item2.frontpath">
                        <el-icon>
                            <component :is="item.icon"></component>
                        </el-icon>
                        <span>{{ item2.name }}</span>
                    </el-menu-item>
                </el-sub-menu>
                <el-menu-item v-else :index="item.frontpath">
                    <el-icon>
                        <component :is="item.icon"></component>
                    </el-icon>
                    <span>{{ item.name }}</span>
                </el-menu-item>
            </template>
        </el-menu>
    </div>
</template>
<script setup>
import { computed } from 'vue'
import { useRouter } from 'vue-router'
const router = useRouter()
import { useStore } from 'vuex';

const store = useStore()

const isCollapse = computed(() => !(store.state.asideWidth == '200px'))
const asideMenus = [
    {
        "name": "后台面板",
        "icon": "home-filled",
        "child": [
            {
                "name": "主控台",
                "icon": "home-filled",
                "frontpath": "/",
            }
        ]
    },
    {
        "name": "商城管理",
        "icon": "shopping-bag",
        "child": [
            {
                "name": "商品管理",
                "icon": "shopping-cart-full",
                "frontpath": "/goods/list",
            }
        ]
    }
]


const handleSelect = (e) => {
    console.log(e)
    router.push(e)
}

</script>
<style scoped>
.f-menu {
    transition: all 0.3s;
    @apply shadow-md fixed bg-light-50;
    top: 64px;
    bottom: 0;
    overflow-y: auto;
    overflow-x: hidden;
}
</style>